﻿#region Using directives

using System;
using System.Data;
using System.Data.Common;
using System.Collections;
using System.Collections.Generic;

using Indeco.G24.Entities;
using Indeco.G24.Data;

#endregion

namespace Indeco.G24.Data.Bases
{	
	///<summary>
	/// This class is the base class for any <see cref="TinTucChuDeProviderBase"/> implementation.
	/// It exposes CRUD methods as well as selecting on index, foreign keys and custom stored procedures.
	///</summary>
	public abstract partial class TinTucChuDeProviderBaseCore : EntityProviderBase<Indeco.G24.Entities.TinTucChuDe, Indeco.G24.Entities.TinTucChuDeKey>
	{		
		#region Get from Many To Many Relationship Functions
		#region GetByIDTinTucFromTinTucTheoChuDe
		
		/// <summary>
		///		Gets tb_TinTucChuDe objects from the datasource by ID_TinTuc in the
		///		tb_TinTucTheoChuDe table. Table tb_TinTucChuDe is related to table tb_TinTuc
		///		through the (M:N) relationship defined in the tb_TinTucTheoChuDe table.
		/// </summary>
		/// <param name="iDTinTuc"></param>
		/// <returns>Returns a typed collection of TinTucChuDe objects.</returns>
		public TList<TinTucChuDe> GetByIDTinTucFromTinTucTheoChuDe(System.Guid iDTinTuc)
		{
			int count = -1;
			return GetByIDTinTucFromTinTucTheoChuDe(null,iDTinTuc, 0, int.MaxValue, out count);
			
		}
		
		/// <summary>
		///		Gets Indeco.G24.Entities.TinTucChuDe objects from the datasource by ID_TinTuc in the
		///		tb_TinTucTheoChuDe table. Table tb_TinTucChuDe is related to table tb_TinTuc
		///		through the (M:N) relationship defined in the tb_TinTucTheoChuDe table.
		/// </summary>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="iDTinTuc"></param>
		/// <remarks></remarks>
		/// <returns>Returns a TList of TinTucChuDe objects.</returns>
		public TList<TinTucChuDe> GetByIDTinTucFromTinTucTheoChuDe(System.Guid iDTinTuc, int start, int pageLength)
		{
			int count = -1;
			return GetByIDTinTucFromTinTucTheoChuDe(null, iDTinTuc, start, pageLength, out count);
		}
		
		/// <summary>
		///		Gets TinTucChuDe objects from the datasource by ID_TinTuc in the
		///		tb_TinTucTheoChuDe table. Table tb_TinTucChuDe is related to table tb_TinTuc
		///		through the (M:N) relationship defined in the tb_TinTucTheoChuDe table.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="iDTinTuc"></param>
		/// <remarks></remarks>
		/// <returns>Returns a typed collection of tb_TinTucChuDe objects.</returns>
		public TList<TinTucChuDe> GetByIDTinTucFromTinTucTheoChuDe(TransactionManager transactionManager, System.Guid iDTinTuc)
		{
			int count = -1;
			return GetByIDTinTucFromTinTucTheoChuDe(transactionManager, iDTinTuc, 0, int.MaxValue, out count);
		}
		
		
		/// <summary>
		///		Gets TinTucChuDe objects from the datasource by ID_TinTuc in the
		///		tb_TinTucTheoChuDe table. Table tb_TinTucChuDe is related to table tb_TinTuc
		///		through the (M:N) relationship defined in the tb_TinTucTheoChuDe table.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="iDTinTuc"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		///  <param name="pageLength">Number of rows to return.</param>
		/// <remarks></remarks>
		/// <returns>Returns a typed collection of tb_TinTucChuDe objects.</returns>
		public TList<TinTucChuDe> GetByIDTinTucFromTinTucTheoChuDe(TransactionManager transactionManager, System.Guid iDTinTuc,int start, int pageLength)
		{
			int count = -1;
			return GetByIDTinTucFromTinTucTheoChuDe(transactionManager, iDTinTuc, start, pageLength, out count);
		}
		
		/// <summary>
		///		Gets TinTucChuDe objects from the datasource by ID_TinTuc in the
		///		tb_TinTucTheoChuDe table. Table tb_TinTucChuDe is related to table tb_TinTuc
		///		through the (M:N) relationship defined in the tb_TinTucTheoChuDe table.
		/// </summary>
		/// <param name="iDTinTuc"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		///  <param name="pageLength">Number of rows to return.</param>
		/// <param name="count">out parameter to get total records for query</param>
		/// <remarks></remarks>
		/// <returns>Returns a typed collection of tb_TinTucChuDe objects.</returns>
		public TList<TinTucChuDe> GetByIDTinTucFromTinTucTheoChuDe(System.Guid iDTinTuc,int start, int pageLength, out int count)
		{
			
			return GetByIDTinTucFromTinTucTheoChuDe(null, iDTinTuc, start, pageLength, out count);
		}


		/// <summary>
		///		Gets tb_TinTucChuDe objects from the datasource by ID_TinTuc in the
		///		tb_TinTucTheoChuDe table. Table tb_TinTucChuDe is related to table tb_TinTuc
		///		through the (M:N) relationship defined in the tb_TinTucTheoChuDe table.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="count">out parameter to get total records for query</param>
		/// <param name="iDTinTuc"></param>
		/// <remarks></remarks>
		/// <returns>Returns a TList of TinTucChuDe objects.</returns>
		public abstract TList<TinTucChuDe> GetByIDTinTucFromTinTucTheoChuDe(TransactionManager transactionManager,System.Guid iDTinTuc, int start, int pageLength, out int count);
		
		#endregion GetByIDTinTucFromTinTucTheoChuDe
		
		#endregion	
		
		#region Delete Methods

		/// <summary>
		/// 	Deletes a row from the DataSource.
		/// </summary>
		/// <param name="transactionManager">A <see cref="TransactionManager"/> object.</param>
		/// <param name="key">The unique identifier of the row to delete.</param>
		/// <returns>Returns true if operation suceeded.</returns>
		public override bool Delete(TransactionManager transactionManager, Indeco.G24.Entities.TinTucChuDeKey key)
		{
			return Delete(transactionManager, key.IDTinTucChuDe);
		}
		
		/// <summary>
		/// 	Deletes a row from the DataSource.
		/// </summary>
		/// <param name="iDTinTucChuDe">. Primary Key.</param>
		/// <remarks>Deletes based on primary key(s).</remarks>
		/// <returns>Returns true if operation suceeded.</returns>
		public bool Delete(System.Guid iDTinTucChuDe)
		{
			return Delete(null, iDTinTucChuDe);
		}
		
		/// <summary>
		/// 	Deletes a row from the DataSource.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="iDTinTucChuDe">. Primary Key.</param>
		/// <remarks>Deletes based on primary key(s).</remarks>
		/// <returns>Returns true if operation suceeded.</returns>
		public abstract bool Delete(TransactionManager transactionManager, System.Guid iDTinTucChuDe);		
		
		#endregion Delete Methods
		
		#region Get By Foreign Key Functions
		#endregion

		#region Get By Index Functions
		
		/// <summary>
		/// 	Gets a row from the DataSource based on its primary key.
		/// </summary>
		/// <param name="transactionManager">A <see cref="TransactionManager"/> object.</param>
		/// <param name="key">The unique identifier of the row to retrieve.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <returns>Returns an instance of the Entity class.</returns>
		public override Indeco.G24.Entities.TinTucChuDe Get(TransactionManager transactionManager, Indeco.G24.Entities.TinTucChuDeKey key, int start, int pageLength)
		{
			return GetByIDTinTucChuDe(transactionManager, key.IDTinTucChuDe, start, pageLength);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the primary key PK_tb_TinTucChuDe index.
		/// </summary>
		/// <param name="iDTinTucChuDe"></param>
		/// <returns>Returns an instance of the <see cref="Indeco.G24.Entities.TinTucChuDe"/> class.</returns>
		public Indeco.G24.Entities.TinTucChuDe GetByIDTinTucChuDe(System.Guid iDTinTucChuDe)
		{
			int count = -1;
			return GetByIDTinTucChuDe(null,iDTinTucChuDe, 0, int.MaxValue, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tb_TinTucChuDe index.
		/// </summary>
		/// <param name="iDTinTucChuDe"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="Indeco.G24.Entities.TinTucChuDe"/> class.</returns>
		public Indeco.G24.Entities.TinTucChuDe GetByIDTinTucChuDe(System.Guid iDTinTucChuDe, int start, int pageLength)
		{
			int count = -1;
			return GetByIDTinTucChuDe(null, iDTinTucChuDe, start, pageLength, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tb_TinTucChuDe index.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="iDTinTucChuDe"></param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="Indeco.G24.Entities.TinTucChuDe"/> class.</returns>
		public Indeco.G24.Entities.TinTucChuDe GetByIDTinTucChuDe(TransactionManager transactionManager, System.Guid iDTinTucChuDe)
		{
			int count = -1;
			return GetByIDTinTucChuDe(transactionManager, iDTinTucChuDe, 0, int.MaxValue, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tb_TinTucChuDe index.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="iDTinTucChuDe"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="Indeco.G24.Entities.TinTucChuDe"/> class.</returns>
		public Indeco.G24.Entities.TinTucChuDe GetByIDTinTucChuDe(TransactionManager transactionManager, System.Guid iDTinTucChuDe, int start, int pageLength)
		{
			int count = -1;
			return GetByIDTinTucChuDe(transactionManager, iDTinTucChuDe, start, pageLength, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tb_TinTucChuDe index.
		/// </summary>
		/// <param name="iDTinTucChuDe"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="count">out parameter to get total records for query</param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="Indeco.G24.Entities.TinTucChuDe"/> class.</returns>
		public Indeco.G24.Entities.TinTucChuDe GetByIDTinTucChuDe(System.Guid iDTinTucChuDe, int start, int pageLength, out int count)
		{
			return GetByIDTinTucChuDe(null, iDTinTucChuDe, start, pageLength, out count);
		}
		
				
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tb_TinTucChuDe index.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="iDTinTucChuDe"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="count">The total number of records.</param>
		/// <returns>Returns an instance of the <see cref="Indeco.G24.Entities.TinTucChuDe"/> class.</returns>
		public abstract Indeco.G24.Entities.TinTucChuDe GetByIDTinTucChuDe(TransactionManager transactionManager, System.Guid iDTinTucChuDe, int start, int pageLength, out int count);
						
		#endregion "Get By Index Functions"
	
		#region Custom Methods
		
		
		#endregion

		#region Helper Functions	
		
		/// <summary>
		/// Fill a Indeco.G24.Entities.TList&lt;TinTucChuDe&gt; From a DataReader.
		/// </summary>
		/// <param name="reader">Datareader</param>
		/// <param name="rows">The collection to fill</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">number of rows.</param>
		/// <returns>a <see cref="Indeco.G24.Entities.TList&lt;TinTucChuDe&gt;"/></returns>
		public static Indeco.G24.Entities.TList<TinTucChuDe> Fill(IDataReader reader, Indeco.G24.Entities.TList<TinTucChuDe> rows, int start, int pageLength)
		{
		// advance to the starting row
		for (int i = 0; i < start; i++)
		{
			if (!reader.Read())
			return rows; // not enough rows, just return
		}
		for (int i = 0; i < pageLength; i++)
		{
			if (!reader.Read())
			break; // we are done
			string key = null;
			
			Indeco.G24.Entities.TinTucChuDe c = null;
			if (DataRepository.Provider.UseEntityFactory)
			{
			key = new System.Text.StringBuilder("TinTucChuDe")
			.Append("|").Append((reader.IsDBNull(((int)Indeco.G24.Entities.TinTucChuDeColumn.IDTinTucChuDe - 1))?Guid.NewGuid():(System.Guid)reader[((int)Indeco.G24.Entities.TinTucChuDeColumn.IDTinTucChuDe - 1)]).ToString()).ToString();
			c = EntityManager.LocateOrCreate<TinTucChuDe>(
			key.ToString(), // EntityTrackingKey
			"TinTucChuDe",  //Creational Type
			DataRepository.Provider.EntityCreationalFactoryType,  //Factory used to create entity
			DataRepository.Provider.EnableEntityTracking); // Track this entity?
			}
			else
			{
			c = new Indeco.G24.Entities.TinTucChuDe();
			}
			
			if (!DataRepository.Provider.EnableEntityTracking ||
			c.EntityState == EntityState.Added ||
			(DataRepository.Provider.EnableEntityTracking &&
			((DataRepository.Provider.CurrentLoadPolicy == LoadPolicy.PreserveChanges && c.EntityState == EntityState.Unchanged) ||
			(DataRepository.Provider.CurrentLoadPolicy == LoadPolicy.DiscardChanges && (c.EntityState == EntityState.Unchanged ||
								c.EntityState == EntityState.Changed)))))
						{
			c.SuppressEntityEvents = true;
			c.IDTinTucChuDe = (System.Guid)reader["ID_TinTucChuDe"];
			c.OriginalIDTinTucChuDe = c.IDTinTucChuDe;
			c.TenChuDe = (System.String)reader["TenChuDe"];
			c.ThoiDiemChinhSua = (System.DateTime)reader["ThoiDiemChinhSua"];
			c.ThoiDiemCapNhat = (System.DateTime)reader["ThoiDiemCapNhat"];
			c.EntityTrackingKey = key;
			c.AcceptChanges();
			c.SuppressEntityEvents = false;
			}
			rows.Add(c);
		}
		return rows;
		}		
		/// <summary>
		/// Refreshes the <see cref="Indeco.G24.Entities.TinTucChuDe"/> object from the <see cref="IDataReader"/>.
		/// </summary>
		/// <param name="reader">The <see cref="IDataReader"/> to read from.</param>
		/// <param name="entity">The <see cref="Indeco.G24.Entities.TinTucChuDe"/> object to refresh.</param>
		public static void RefreshEntity(IDataReader reader, Indeco.G24.Entities.TinTucChuDe entity)
		{
			if (!reader.Read()) return;
			
			entity.IDTinTucChuDe = (System.Guid)reader["ID_TinTucChuDe"];
			entity.OriginalIDTinTucChuDe = (System.Guid)reader["ID_TinTucChuDe"];
			entity.TenChuDe = (System.String)reader["TenChuDe"];
			entity.ThoiDiemChinhSua = (System.DateTime)reader["ThoiDiemChinhSua"];
			entity.ThoiDiemCapNhat = (System.DateTime)reader["ThoiDiemCapNhat"];
			entity.AcceptChanges();
		}
		
		/// <summary>
		/// Refreshes the <see cref="Indeco.G24.Entities.TinTucChuDe"/> object from the <see cref="DataSet"/>.
		/// </summary>
		/// <param name="dataSet">The <see cref="DataSet"/> to read from.</param>
		/// <param name="entity">The <see cref="Indeco.G24.Entities.TinTucChuDe"/> object.</param>
		public static void RefreshEntity(DataSet dataSet, Indeco.G24.Entities.TinTucChuDe entity)
		{
			DataRow dataRow = dataSet.Tables[0].Rows[0];
			
			entity.IDTinTucChuDe = (System.Guid)dataRow["ID_TinTucChuDe"];
			entity.OriginalIDTinTucChuDe = (System.Guid)dataRow["ID_TinTucChuDe"];
			entity.TenChuDe = (System.String)dataRow["TenChuDe"];
			entity.ThoiDiemChinhSua = (System.DateTime)dataRow["ThoiDiemChinhSua"];
			entity.ThoiDiemCapNhat = (System.DateTime)dataRow["ThoiDiemCapNhat"];
			entity.AcceptChanges();
		}
		#endregion 
		
		#region DeepLoad Methods
		/// <summary>
		/// Deep Loads the <see cref="IEntity"/> object with criteria based of the child 
		/// property collections only N Levels Deep based on the <see cref="DeepLoadType"/>.
		/// </summary>
		/// <remarks>
		/// Use this method with caution as it is possible to DeepLoad with Recursion and traverse an entire object graph.
		/// </remarks>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="entity">The <see cref="Indeco.G24.Entities.TinTucChuDe"/> object to load.</param>
		/// <param name="deep">Boolean. A flag that indicates whether to recursively save all Property Collection that are descendants of this instance. If True, saves the complete object graph below this object. If False, saves this object only. </param>
		/// <param name="deepLoadType">DeepLoadType Enumeration to Include/Exclude object property collections from Load.</param>
		/// <param name="childTypes">Indeco.G24.Entities.TinTucChuDe Property Collection Type Array To Include or Exclude from Load</param>
		/// <param name="innerList">A collection of child types for easy access.</param>
	    /// <exception cref="ArgumentNullException">entity or childTypes is null.</exception>
	    /// <exception cref="ArgumentException">deepLoadType has invalid value.</exception>
		internal override void DeepLoad(TransactionManager transactionManager, Indeco.G24.Entities.TinTucChuDe entity, bool deep, DeepLoadType deepLoadType, System.Type[] childTypes, DeepSession innerList)
		{
			if(entity == null)
				return;
			
			//used to hold DeepLoad method delegates and fire after all the local children have been loaded.
			Dictionary<string, KeyValuePair<Delegate, object>> deepHandles = new Dictionary<string, KeyValuePair<Delegate, object>>();
			// Deep load child collections  - Call GetByIDTinTucChuDe methods when available
			
			#region TinTucCollection_From_TinTucTheoChuDe
			// RelationshipType.ManyToMany
			if (CanDeepLoad(entity, "List<TinTuc>|TinTucCollection_From_TinTucTheoChuDe", deepLoadType, innerList))
			{
				entity.TinTucCollection_From_TinTucTheoChuDe = DataRepository.TinTucProvider.GetByIDTinTucChuDeFromTinTucTheoChuDe(transactionManager, entity.IDTinTucChuDe);			 
		
				#if NETTIERS_DEBUG
				System.Diagnostics.Debug.WriteLine("- property 'TinTucCollection_From_TinTucTheoChuDe' loaded. key " + entity.EntityTrackingKey);
				#endif 
				
				if (deep && entity.TinTucCollection_From_TinTucTheoChuDe != null)
				{
					deepHandles.Add("TinTucCollection_From_TinTucTheoChuDe",
						new KeyValuePair<Delegate, object>((DeepLoadHandle< TinTuc >) DataRepository.TinTucProvider.DeepLoad,
						new object[] { transactionManager, entity.TinTucCollection_From_TinTucTheoChuDe, deep, deepLoadType, childTypes, innerList }
					));
				}
			}
			#endregion
			
			
			
			#region TinTucTheoChuDeCollection
			//Relationship Type One : Many
			if (CanDeepLoad(entity, "List<TinTucTheoChuDe>|TinTucTheoChuDeCollection", deepLoadType, innerList)) 
			{
				#if NETTIERS_DEBUG
				System.Diagnostics.Debug.WriteLine("- property 'TinTucTheoChuDeCollection' loaded. key " + entity.EntityTrackingKey);
				#endif 

				entity.TinTucTheoChuDeCollection = DataRepository.TinTucTheoChuDeProvider.GetByIDTinTucChuDe(transactionManager, entity.IDTinTucChuDe);

				if (deep && entity.TinTucTheoChuDeCollection.Count > 0)
				{
					deepHandles.Add("TinTucTheoChuDeCollection",
						new KeyValuePair<Delegate, object>((DeepLoadHandle<TinTucTheoChuDe>) DataRepository.TinTucTheoChuDeProvider.DeepLoad,
						new object[] { transactionManager, entity.TinTucTheoChuDeCollection, deep, deepLoadType, childTypes, innerList }
					));
				}
			}		
			#endregion 
			
			
			//Fire all DeepLoad Items
			foreach(KeyValuePair<Delegate, object> pair in deepHandles.Values)
		    {
                pair.Key.DynamicInvoke((object[])pair.Value);
		    }
			deepHandles = null;
		}
		
		#endregion 
		
		#region DeepSave Methods

		/// <summary>
		/// Deep Save the entire object graph of the Indeco.G24.Entities.TinTucChuDe object with criteria based of the child 
		/// Type property array and DeepSaveType.
		/// </summary>
		/// <param name="transactionManager">The transaction manager.</param>
		/// <param name="entity">Indeco.G24.Entities.TinTucChuDe instance</param>
		/// <param name="deepSaveType">DeepSaveType Enumeration to Include/Exclude object property collections from Save.</param>
		/// <param name="childTypes">Indeco.G24.Entities.TinTucChuDe Property Collection Type Array To Include or Exclude from Save</param>
		/// <param name="innerList">A Hashtable of child types for easy access.</param>
		internal override bool DeepSave(TransactionManager transactionManager, Indeco.G24.Entities.TinTucChuDe entity, DeepSaveType deepSaveType, System.Type[] childTypes, DeepSession innerList)
		{	
			if (entity == null)
				return false;
							
			#region Composite Parent Properties
			//Save Source Composite Properties, however, don't call deep save on them.  
			//So they only get saved a single level deep.
			#endregion Composite Parent Properties

			// Save Root Entity through Provider
			if (!entity.IsDeleted)
				this.Save(transactionManager, entity);
			
			//used to hold DeepSave method delegates and fire after all the local children have been saved.
			Dictionary<Delegate, object> deepHandles = new Dictionary<Delegate, object>();

			#region TinTucCollection_From_TinTucTheoChuDe>
			if (CanDeepSave(entity.TinTucCollection_From_TinTucTheoChuDe, "List<TinTuc>|TinTucCollection_From_TinTucTheoChuDe", deepSaveType, innerList))
			{
				if (entity.TinTucCollection_From_TinTucTheoChuDe.Count > 0 || entity.TinTucCollection_From_TinTucTheoChuDe.DeletedItems.Count > 0)
				{
					DataRepository.TinTucProvider.Save(transactionManager, entity.TinTucCollection_From_TinTucTheoChuDe); 
					deepHandles.Add(
						(DeepSaveHandle<TinTuc>) DataRepository.TinTucProvider.DeepSave,
						new object[] { transactionManager, entity.TinTucCollection_From_TinTucTheoChuDe, deepSaveType, childTypes, innerList }
					);
				}
			}
			#endregion 
	
			#region List<TinTucTheoChuDe>
				if (CanDeepSave(entity.TinTucTheoChuDeCollection, "List<TinTucTheoChuDe>|TinTucTheoChuDeCollection", deepSaveType, innerList)) 
				{	
					// update each child parent id with the real parent id (mostly used on insert)
					foreach(TinTucTheoChuDe child in entity.TinTucTheoChuDeCollection)
					{
						if(child.IDTinTucChuDeSource != null)
							child.IDTinTucChuDe = child.IDTinTucChuDeSource.IDTinTucChuDe;
						else
							child.IDTinTucChuDe = entity.IDTinTucChuDe;

						//Handle right table of TinTucCollection_From_TinTucTheoChuDe
						if(child.IDTinTucSource != null)
						{
								child.IDTinTuc = child.IDTinTucSource.IDTinTuc;

						}

						//Handle right table of TinTucCollection_From_TinTucTheoChuDe
						if(child.IDTinTucChuDeSource != null)
						{
								child.IDTinTucChuDe = child.IDTinTucChuDeSource.IDTinTucChuDe;

						}

					}

					if (entity.TinTucTheoChuDeCollection.Count > 0 || entity.TinTucTheoChuDeCollection.DeletedItems.Count > 0)
					{
						DataRepository.TinTucTheoChuDeProvider.Save(transactionManager, entity.TinTucTheoChuDeCollection);
						
						deepHandles.Add(
							(DeepSaveHandle< TinTucTheoChuDe >) DataRepository.TinTucTheoChuDeProvider.DeepSave,
							new object[] { transactionManager, entity.TinTucTheoChuDeCollection, deepSaveType, childTypes, innerList }
						);
					}
				} 
			#endregion 
				
			//Fire all DeepSave Items
			foreach(KeyValuePair<Delegate, object> pair in deepHandles)
		    {
                pair.Key.DynamicInvoke((object[])pair.Value);
		    }
			
			// Save Root Entity through Provider, if not already saved in delete mode
			if (entity.IsDeleted)
				this.Save(transactionManager, entity);
				

			deepHandles = null;
						
			return true;
		}
		#endregion
	} // end class
	
	#region TinTucChuDeChildEntityTypes
	
	///<summary>
	/// Enumeration used to expose the different child entity types 
	/// for child properties in <c>Indeco.G24.Entities.TinTucChuDe</c>
	///</summary>
	public enum TinTucChuDeChildEntityTypes
	{

		///<summary>
		/// Collection of <c>TinTucChuDe</c> as ManyToMany for TinTucCollection_From_TinTucTheoChuDe
		///</summary>
		[ChildEntityType(typeof(TList<TinTuc>))]
		TinTucCollection_From_TinTucTheoChuDe,

		///<summary>
		/// Collection of <c>TinTucChuDe</c> as OneToMany for TinTucTheoChuDeCollection
		///</summary>
		[ChildEntityType(typeof(TList<TinTucTheoChuDe>))]
		TinTucTheoChuDeCollection,
	}
	
	#endregion TinTucChuDeChildEntityTypes
	
	#region TinTucChuDeFilterBuilder
	
	/// <summary>
	/// A strongly-typed instance of the <see cref="SqlFilterBuilder&lt;TinTucChuDeColumn&gt;"/> class
	/// that is used exclusively with a <see cref="TinTucChuDe"/> object.
	/// </summary>
	[CLSCompliant(true)]
	public class TinTucChuDeFilterBuilder : SqlFilterBuilder<TinTucChuDeColumn>
	{
		#region Constructors

		/// <summary>
		/// Initializes a new instance of the TinTucChuDeFilterBuilder class.
		/// </summary>
		public TinTucChuDeFilterBuilder() : base() { }

		/// <summary>
		/// Initializes a new instance of the TinTucChuDeFilterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		public TinTucChuDeFilterBuilder(bool ignoreCase) : base(ignoreCase) { }

		/// <summary>
		/// Initializes a new instance of the TinTucChuDeFilterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		/// <param name="useAnd">Specifies whether to combine statements using AND or OR.</param>
		public TinTucChuDeFilterBuilder(bool ignoreCase, bool useAnd) : base(ignoreCase, useAnd) { }

		#endregion Constructors
	}

	#endregion TinTucChuDeFilterBuilder
	
	#region TinTucChuDeParameterBuilder
	
	/// <summary>
	/// A strongly-typed instance of the <see cref="ParameterizedSqlFilterBuilder&lt;TinTucChuDeColumn&gt;"/> class
	/// that is used exclusively with a <see cref="TinTucChuDe"/> object.
	/// </summary>
	[CLSCompliant(true)]
	public class TinTucChuDeParameterBuilder : ParameterizedSqlFilterBuilder<TinTucChuDeColumn>
	{
		#region Constructors

		/// <summary>
		/// Initializes a new instance of the TinTucChuDeParameterBuilder class.
		/// </summary>
		public TinTucChuDeParameterBuilder() : base() { }

		/// <summary>
		/// Initializes a new instance of the TinTucChuDeParameterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		public TinTucChuDeParameterBuilder(bool ignoreCase) : base(ignoreCase) { }

		/// <summary>
		/// Initializes a new instance of the TinTucChuDeParameterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		/// <param name="useAnd">Specifies whether to combine statements using AND or OR.</param>
		public TinTucChuDeParameterBuilder(bool ignoreCase, bool useAnd) : base(ignoreCase, useAnd) { }

		#endregion Constructors
	}

	#endregion TinTucChuDeParameterBuilder
} // end namespace
